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Résumé : Le projet TAAABLE a pour objet de construire un système de raison- 
nement à partir de cas pour la recherche et l'adaptation de textes de recettes de 
cuisine. Dans ce cadre, nous nous intéressons aux aspects temporels des recettes 
et à la manière de les représenter afin d'en envisager l'adaptation textuelle. 
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1 Introduction 

TAAABLE ( [Badra et al.\ |2008[ l est un système informatique destiné à résoudre des 
problèmes de cuisine, développé dans le cadre du Computer Cooking Contes^ dans le 
cadre duquel des requêtes du type «je désire la recette d'un plat de pâtes aux lentilles » 
doivent être résolues en cherchant dans un livre fourni par les organisateurs du concours 
une recette qui répond aux critères de l'utilisateur. Si une telle recette n'existe pas, un 
moteur de raisonnement à partir de cas sélectionne une recette similaire et suggère une 
adaptation. Initialement, l'adaptation ne portait que sur la liste d'ingrédients, mais la 



dernière version du système ( |Blansché et al. 2010) > tient compte des instructions tex 



nielles de préparation dans le raisonnement et l'adaptation. Le raisonnement ne pouvant 
porter directement sur du texte brut, il est nécessaire de choisir un formalisme de re- 
présentation de cas et d'employer des méthodes de traitement automatique des langues 
pour créer ces représentations. TAAABLE utilise actuellement un formalisme ad hoc 



1. http://liris.cnrs.fr/ccc/ccc2010 
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Lutheran Hotdish 

- 1 lb Hamburger 

- 1/2 lb Mild or spicy sausage 

- 1 lg Onion (sliced and quartered) (up to) 

- 5 Cloves garlic (minced) (up to) 

- 2 en Kidney beans (drained) 

- 1 lb Uncooked pasta (i.e. elbow ; twisted ; wagon wheels, shells ; etc) (up to) 
Brown hamburger and sausage with onion, garlic, and ail seasonings. Meanwhile, pré- 
pare the pasta per pkg instructions. In a large pan, combine ail ingrédients. Add enough 
tomato sause until mixture is well coated, but no soupy. When well mixed, pour into 
greased and covered casserai dish and bake at 350F for lhr. Remove cover for the last 
15 minutes. Then enjoy. 

Figure 1 - Une recette issue du livre fourni par le Computer Cooking Contest, illus- 
trant certains phénomènes temporels intéressants. 

fondé sur les combinaisons d'ingrédients pour ce faire, bien que |Le Ber et al. | ([2009 
|2010| l aient initié une réflexion quant à un formalisme plus expressif et plus approprié. 

Cet article poursuit cette réflexion. Dans la section [2] nous présentons les différents 
types de phénomènes temporels observés dans les textes de recette, des plus simples à 
représenter aux plus complexes. Puis, dans la section[3] nous définissons le type de rai- 
sonnement que nous entendons appliquer aux recettes avant de passer en revue, dans la 
section|4] quelques formalismes qui semblent appropriés à la représentation de ces phé- 
nomènes. La section[5]présente de façon concise l'adéquation que nous observons entre 
les phénomènes à modéliser et les formalismes étudiés. Finalement, dans la section [6] 
nous concluons et présentons succinctement les travaux futurs que nous comptons ac- 
complir à partir de nos résultats. 

2 Problématiques de représentation temporelle 

Nous dressons d'abord une liste des phénomènes temporels que le formalisme retenu 
devrait être capable de représenter. La figure [T] présente une recette du livre employé 
par Taaable pour répondre aux requêtes des utilisateurs, reproduite telle quelle. 

2.1 Durée 

Pour les événements ayant une durée, celle-ci peut être définie explicitement de ma- 
nière quantitative, comme c'est le cas des dernières instructions de la recette montrée 
en figure [T](« bake at 350F for lhr »), ou encore implicitement en référence à un chan- 
gement d'état (« Add enough tomato sauce until mixture is well coated »), ce que nous 
appellerons « durée qualitative ». Certaines recettes peuvent préciser les deux (« Bake 
at 350 degrees for about 25 minutes, or until lightly browned »), auquel cas une sé- 
mantique doit être déterminée : s'agit-il réellement d'une disjonction — l'action se 
conclut-elle dès que 25 minutes se sont écoulées ou que la couleur a changé ? 
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2.2 Ordre 

Les actions nécessaires à l'exécution d'une recette de cuisine ne peuvent pas être 
effectuées dans n'importe quel ordre. La plupart des actions sont ordonnées implicite- 
ment, puisqu'il est entendu que, dans une recette de cuisine, les actions décrites à même 
la liste d'ingrédients sont à accomplir avant le début de la recette proprement dite, et 
que les actions décrites dans le texte doivent être effectuées dans l'ordre où elles sont 
énoncées, sauf mention contraire. 

Dans la recette de la figure [T] les actions préliminaires (couper l'oignon, hacher l'ail 
et égoutter les haricots) doivent être effectuées avant que la première action décrite dans 
le texte (« Brown hamburger and sausage... ») soit initiée. Cependant il semble que ces 
actions puissent être exécutées dans n'importe quel ordre, puisqu'elles ne dépendent pas 
l'une des autres : on peut couper l'oignon avant de hacher l'ail ou après, car l'aliment 
résultant de chacune de ces actions n'est pas utilisé pour l'autre. 

Dans le texte même, certains adverbes ont pour effet de changer l'ordre normal d'exé- 
cution des actions. Par exemple, l'action décrite par la deuxième phrase (« Meanwhile, 
prépare pasta... ») doit être effectuée simultanément à la première action. La troisième 
phrase (« In a large pan, combine ail ingrédients ») ne précise pas de relation d'ordre 
explicite, de quoi on peut conclure que l'action doit être effectuée à la suite de l'action 
précédente. 

Il est à noter que le moment d'exécution d'une action peut être défini en référence 
à la fin d'un intervalle, comme dans « Remove cover for the last 15 minutes. » Cet 
intervalle de référence peut être imprécis, comme dans « simmer 2-3 hours », ajoutant 
une difficulté additionnelle. 



2.3 Actions répétées 

Les actions répétées suggèrent une structure non linéaire du temps. Différentes situa- 
tions peuvent poser différents problèmes de représentation. Une même action peut être 
répétée un nombre déterminé ou indéterminé (jusqu'à l'obtention d'un état donné) de 
fois, ou une série d'actions peuvent être répétées en alternance, possiblement avec des 
conditions d'ordre précises. Une action peut également être répétée de façon sporadique 
sur un intervalle donné, comme dans « simmer 2-3 hours, stirring occasionally ». 



2.4 Disjonction 

Les disjonctions d'actions constituent un dernier élément pouvant poser des difficul- 
tés de représentation. Celles-ci peuvent être liées à un état, ou encore représenter des 
alternatives dans une recette : « If you want this relish to be really hot then take 4 green 
chillis, seed them and chop finely, and put them in the frying pan at the same time as 
the onions. » 
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3 Raisonnement 

Avant de discuter des formalismes que nous envisageons d'utiliser pour représenter 
les recettes, il convient de mieux définir le type de raisonnement que nous souhaitons 
appliquer à ces recettes. Si l'utilisateur lance la requête donnée en exemple dans l'intro- 
duction, c'est-à-dire un plat de pâtes aux lentilles, Taaable retournera comme résultat 
la recette de la figure [T] en suggérant de remplacer les haricots rouges en conserve par 
des lentilles. 

Pour adapter le texte de préparation de manière adéquate, il ne suffira pas de rem- 
placer toutes les instances d'« haricots » par « lentilles ». Il faut également introduire 
au bon endroit des informations issues des connaissances du domaine : par exemple, 
que les lentilles doivent cuire à l'eau pendant une demi -heure puis être égouttées avant 
d'intégrer la préparation. Pour représenter adéquatement les relations entre ces actions 
(pendant, puis, avant), il sera nécessaire d'employer une représentation temporelle. 

Une manière de tenir compte de connaissances liées à un élément de substitution en 
raisonnement à partir de cas est l'adaptation par révision, proposée par Cojan & Lieber 



(2008) : il s'agit d'adjoindre ces connaissances à celles issues du cas remémoré (ici, 
la recette du « Lutheran Hotdish ») en résolvant les contradictions éventuelles à l'aide 
d'un opérateur de révision des croyances, de manière à conserver toute l'information 
issue des connaissances du domaine et le maximum d'information issue du cas. 

Un tel opérateur applicable aux algèbres qualitatives pourrait être dérivé des travaux 
de Condotta et al. ( 2009 ) sur la fusion des réseaux de contraintes qualitatives. 



Une fois la représentation de la préparation de la recette adaptée par révision avec les 
connaissances du domaine, et à condition de pouvoir maintenir le lien entre le texte et 
cette représentation au cours de l'adaptation, il sera possible d'apporter les modifica- 
tions correspondantes au texte. 



4 Formalismes envisagés 

Les formalismes de représentation temporelle sont généralement divisés en deux ca- 
tégories par la communauté IA, en fonction du type de raisonnement envisagé. Les 
raisonnements sur les contraintes temporelles font généralement appel à des forma- 
lismes algébriques tels que les algèbres d'intervalle, que nous étudierons en particulier. 
Les raisonnements sur les actions et leurs effets sur des domaines dynamiques, quant à 
eux, donnent le plus souvent lieu à l'utilisation de formalismes inspirés du calcul des 
situations, qui sont moins appropriés à notre problème^] 

Nous nous pencherons brièvement sur des formalismes dont le but principal est de 
résoudre certains problèmes de représentation des informations temporelles dans les 
textes, ainsi que sur les flux opérationnels (workflows), représentant des processus et 
pouvant être utilisés pour raisonner sur ceux-ci. 



2. Nous n'entendons pas que ces formalismes ne seraient pas utiles pour l'adaptation dans TAAABLE, 
et au contraire nous souhaitons étudier la contribution qu'ils pourraient apporter ultérieurement, mais le pro- 
blème que nous cherchons à résoudre ici est relatif aux contraintes temporelles entre les actions, et non pas 
au raisonnement sur les actions et leurs effets. 
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4.1 Algèbres de relations 

4.1.1 Contraintes qualitatives 

Nous débutons notre exploration par l'algèbre des intervalles de |Allen| ( |1983[ ), qui 
nous semble particulièrement adaptée à la représentation des phénomènes les plus fré- 
quents. Cet algèbre permet d'exprimer des relations entre des intervalles temporels sous 
la forme de disjonctions entre treize relations de base : before (notée b, < ou p), meets 
(m), overlaps (o), during (d), starts (s),finishes (f), les inverses de ces six relations (res- 
pectivement bi — ou encore >, pi ou a — , mi, oi, di, si et fi), ainsi que equals (e, eq ou 
=)■ 

En associant chaque action à un intervalle, il est facile d'en représenter l'ordre. Dans 
la recette de la figure [T] on aurait par exemple : 

- 'mince garlic' {b} 'brown hamburger' 

- 'prépare pasta' {d,f} 'brown hamburger' 

- 'combine ail ingrédients' {bi,m} 'prépare pasta' 

En associant des états à des intervalles, on pourrait représenter les durées définies par 
un changement d'état, comme dans le cas de « 'add tomato sauce' {m} 'mixture is well 
coated' ». 

Grâce à lAfVU (Pujari et al. 1999| l, qui permet additionnellement d'exprimer des 



contraintes qualitatives sur la durée des intervalles (par exemple, un intervalle 1\ dont la 
fin coïncide avec le début d'un intervalle I2 et dont la durée est inférieure à celle de ce 
dernier s'exprime « 1\ {m^ } I2 »), il serait également possible de représenter jusqu'à 
un certain point des durées quantitatives en définissant des intervalles de durée fixe, 
par exemple : « 'bake' { ? = } 'une heure' ». Cette même méthode nous permettrait de 
représenter aussi la dernière action de la recette : « 'remove cover' {s } '15 minutes' 
{f- } 'bake' ». Pour représenter la durée d'une qui est exprimée à la fois quantitativement 
et qualitativement, comme dans « Bake at 350 degrees for about 25 minutes, or until 
lightly brown », nous pouvons prendre le parti d'exprimer que la durée de 25 minutes 
constitue un maximum et écrire « 'bake' fnv } 'is brown', 'bake' f ?^ } '25 minutes' ». 



Ladkin ( 1986] > et |Lig ozat ( 1991 ), entre autres, ont proposé des extensions à l'algèbre 



de Allen afin qu'elle puisse exprimer des contraintes sur des intervalles non convexes. 
En définissant une propriété « cet intervalle est non convexe » applicable aux intervalles 
représentant une action qui se répète avec au moins deux occurrences disjointes, on 
serait capable d'exprimer ce que nous appellerons des « actions répétées sporadique », 
comme dans l'exemple ci-haut, « simmer 2-3 hours, stirring occasionally » : « 'simmer' 
{contains} 'stir' », où 'stir' est un intervalle non convexe. Il pourrait en revanche être 
plus simple pour le raisonnement de représenter une action répétée sporadiquement sur 
un intervalle convexe spécialement qualifié : « 'simmer' {di} 'stir (sporadiquement)' ». 
Balbiani & Osmani ( 1999] ) ont pour leur part proposé une extension permettant d'ex- 



primer des contraintes sur des intervalles cycliques, qui sont représentés sur un cercle 
plutôt que sur une droite. Ces c_intervalles seraient utiles pour la représentation des ac- 
tions répétées : par exemple, on pourrait représenter « add milk and flour in alternance a 
little at a time » par « 'add milk' {mmi} 'add flour' », où « mmi » représente la conjonc- 
tion de « m » et « mi ». En revanche, les c_intervalles ne permettent pas de représenter 
les relations de précédence temporelle. 
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4.1.2 Contraintes métriques 



Dechter et al. ( 1991| > ont proposé un formalisme, l'algèbre de distance, permettant de 



représenter et de raisonner sur des contraintes métriques exprimées sur des points, qui 
sont des variables réelles. Une contrainte binaire dans cette algèbre est une disjonction 
d'expressions sous la forme « min ^ Xj — Xi ^ max ». On pourrait donc représenter 
la durée d'une action comme « simmer 2-3 hours » par « 2 < I^ mmel ~ ^simmer ^ 3 ». 
Si toutes les contraintes sur les intervalles ne peuvent pas être exprimées (par exemple, 
la disjonction d'intervalles {b,bi}), il semble que les contraintes utiles à la représenta- 
tion des recettes de cuisine soient toutes exprimables, bien que pas toujours de façon 
très intuitive. Cependant, il existe un formalisme simple proposé par |Kautz & La dkin 
( | 199 ip qui permet de représenter à la fois des contraintes métriques et des contraintes 
qualitatives sur des intervalles. 

4.2 Représentations proposées par la linguistique informatique 

Plusieurs formalismes temporels ont été proposés par des linguistes informaticiens 
spécifiquement pour représenter des informations temporelles extraites de textes, ou an- 
noter des textes — c'est-à-dire ajouter une couche d'information formelle. Le langage 



d'annotation le plus expressif à notre connaissance est TimeML (Pustejovsky et al. 
2004). Celui-ci permet d'exprimer des relations entre des actions, des états, des inter- 
valles, des points dans le temps et même des intervalles non convexes exprimés sous 
la forme d'« ensembles de repères temporels ». En termes de relations pouvant être 
encodées, TimeML est sans doute comparable aux algèbres combinant contraintes qua- 
litatives et quantitatives, mais il n'est pas associé à une sémantique ni à des règles 
d'inférences, bien que certaines applications existantes proposent de telles règles, no- 
tamment le système de question-réponse de Harabagiu & Bejan (2005 ). 

Voici par exemple les deux premières phrases de la recette de la figure [T] annotées 
en TimeML. Les balises EVENT soulignent ici les verbes, qui correspondent à des 
intervalles, alors que la balise SIGNAL souligne le mot exprimant la relation temporelle 
existant entre les événements correspondant à chacun des verbes, qui est formalisée par 
la balise TLINK — la relation IS_INCLUDED correspond exactement à la relation { di } 
en algèbre des intervalles. 

<EVENT eid="el" class="OCCURENCE"> Brown </EVENT> 
<MAKE INSTANCE eiid="eil" eventID="el" t ense= " INFINITIVE " 
aspect = "NONE" pos = "VERB" / > hamburger and sausage with onion, garlic, 
and ail seasonings. <SIGNAL sid="sl"> Meanwhile </SIGNAL>, <EVENT 
eid="e2" class="OCCURENCE"> prépare </EVENT> <MAKE INSTANCE 
eiid="ei2" eventID="e2" tense=" INFINITIVE" aspect="NONE" 
pos="VERB" /> the pasta per pkg instructions. <TLINK 

eventInstanceID="ei2" signalID="sl" relatedToEvent="eil " 
relType="IS_INCLUDED"/> 

Les langages d'annotation permettent d'associer des contraintes directement à des 
mots. Pour raisonner sur des textes, et en particulier pour l'adaptation, cela constitue un 
avantage considérable : ainsi, toute modification dans le réseau de contrainte peut plus 
facilement être reportée sur le texte. 
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Prépare pasta j~> 








->| Combine 


ail ingrédients ]->[ Add tomato sauce |->j Pour Into casserai dish |->[ Bake for lhr|->j Remove cover for the last 15 minutej-*((j|) 




A- 


n hamburger and onion..J+ 





FIGURE 2 - La recette de la figure [l] formalisée sous forme de flux opérationnel. Les 
actions entre les deux bandes noires sont conjointes, définissant un ordre partiel. 



4.3 Flux opérationnels ( workflows ) 

Un flux opérationnel est une modélisation d'un ensemble d'actions qui doivent être 
accomplies, éventuellement par différents acteurs, pour réaliser une tâche. Si les pos- 
sibilités expressives temporelles des flux sont assez restreintes, étant essentiellement 
limitées à spécifier l'ordre des actions ou éventuellement la possibilité de les accomplir 
en parallèle, ils présentent par ailleurs une plus grande richesse en terme de structures 
de contrôle. En particulier, il est facile d'exprimer des disjonctions et des boucles, qui 
sont les phénomènes qui nous posent le plus de problème pour la représentation algé- 
brique temporelle des recettes de cuisine. Les flux opérationnels sont d'ailleurs déjà 



employés par Minor et al. (2010 1 pour l'adaptation de recettes. Cependant, tout comme 
les formalismes d'annotation de texte, les flux ne sont pas à proprement parler associés 
à une sémantique et à des processus d'inférence. Il faut noter par ailleurs qu'il existe 
de nombreux langages de flux proposant différents niveaux d'expressivité, et que les 
langages les plus expressifs peuvent s'apparenter à des langages algorithmiques et donc 
poser des problèmes de décidabilité. La figure|2]montre le texte de recette de la figure[T] 
formalisé sous forme de flux opérationnel. 



5 Synthèse 

La tablefïlreprend les principaux phénomènes à représenter dans les recettes identifiés 
à la section|2]afin de noter ceux pour lesquels nous croyons avoir identifié une manière 
de les exprimer dans les différents formalismes présentés dans la section [4] Bien en- 
tendu, le fait que nous n'ayons pas identifié une manière de représenter un phénomène 
donné dans un formalisme ne constitue pas une preuve que cette manière n'existe pas. 



6 Conclusion 

Notre première constatation est que chaque phénomène que nous souhaitons repré- 
senter est exprimable dans au moins un formalisme étudié, mais qu'aucun formalisme 
ne semble capable d'exprimer tous les phénomènes. La question qui se pose donc est 
de savoir s'il faut créer un nouveau formalisme ou étendre un formalisme existant, 
ou encore s'il est possible de combiner certains formalismes que nous avons étudiés. 
En particulier, Condotta et al. d2009 ) se sont penchés sur le problème de la fusion 



de connaissances spatio-temporelles à travers l'utilisation de réseaux de contraintes 
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TABLE 1 - Adéquation entre les phénomènes temporels à représenter et les forma- 
lismes. Les types de durée sont définis à la section |2~Tj les types d'ordre et la simulta- 



néité à la section 2.2 les types de répétition d'action à la section 2.3 et la disjonction à 



la section 2.4 



a. On peut représenter ces phénomènes en combinant une boucle et une instruction de type « no opération ». 



qualitatives issues de différents formalismes. Ces travaux constituent une base intéres- 
sante sur laquelle nous comptons nous appuyer pour nos travaux futurs sur l'adaptation 
spatio-temporelle mais, plus spécifiquement, ils créent également un cadre permettant 
de combiner différentes algèbres qualitatives. A long terme, il serait intéressant d'étu- 
dier certains des formalismes que nous avons laissés de côté, par exemple ceux liés à la 
représentation des actions et des changements et ceux liés à la planification — en parti- 
culier, il existe une littérature assez étendue sur la planification à partir de cas, qui pour- 
rait constituer une approche complémentaire à celle que nous tentons de développer. 
Par exemple, le calcul des situations ou un formalisme apparenté pourrait être employé 
pour vérifier que la cohérence d'une recette est maintenue après son adaptation. 

Nous avons concentré notre attention sur les recettes de cuisine, mais notre étude 
aurait pu s'appliquer à plusieurs autres types de textes, voire de cas non textuels. En ef- 
fet, plusieurs ensembles de cas de type procédural, que ce soient des instructions d'as- 
semblage, de préparation pharmaceutique ou de réparation de locomotive, pourraient 
bénificier d'une procédure d'adaptation automatique lorsque l'une des pré-conditions 
requises à l'exécution de la procédure n'est pas respectée. Les mêmes types de repré- 
sentation et de raisonnement pourraient alors être employés. Par ailleurs, l'approche 
que nous souhaitons développer sera applicable également au raisonnement à partir 
de cas spaciaux ou spatio-temporels — par exemple pour l'adaptation d'itinéraires ou 
l'aide à la prise de décision sur des projets d'aménagement agricole — , soulevant des 
problèmes de représentation similaires. 
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